草庐IT

java - 将 FileObject 转换为文件

全部标签

ruby - 如何在我的 .rb 文件中共享变量?

我有几个.rb文件,我想在所有文件中使用相同的变量。假设变量test_variable="test"应该可以从我所有的.rb访问文件。我怎样才能做到这一点?我创建了settings.rb文件test_variable="test"然后使用require'settings'在另一个.rb文件,但没有用。我想使用require不是load.我试图通过在变量名称前加上$来使变量成为全局变量,但我仍然得到undefinedlocalvariableormethod'test_variable'formain:Object(NameError). 最佳答案

ruby-on-rails - 将日期时间转换为月、日和年?

我好像找不到这个,我觉得应该很容易。在RubyonRails中,我如何采取:2010-06-1419:01:00UTC把它变成June14th,2010我不能只在View中使用助手吗? 最佳答案 我不知道June14th,2010但如果你想June14,2010引用howdoigetnameofthemonthinrubyonRails?或this就这样@date=Time.now@date.strftime("%B%d,%Y")后缀用在后面@date.strftime("%B#{@date.day.ordinalize},%Y")

ruby - 用 ruby​​ 解压 (zip, tar, tag.gz) 文件

我想解压缩很多zip文件。是否有模块或脚本检查zip文件的格式并解压缩它?这应该适用于Linux,我不关心其他操作系统。 最佳答案 要从.tar.gz文件中提取文件,您可以使用以下方法从随Ruby分发的包中:require'rubygems/package'require'zlib'tar_extract=Gem::Package::TarReader.new(Zlib::GzipReader.open('Path/To/myfile.tar.gz'))tar_extract.rewind#Theextracthastoberewi

ruby - 我怎样才能避免在 Ruby 1.9 中的每个 UTF-8 文件的顶部放置神奇的编码注释?

我有一个Rails项目,里面有很多西里尔字符串。它在Ruby1.8上运行良好,但Ruby1.9假定源文件是US-ASCII编码的,除非您在源文件顶部提供#encoding:utf-8注释。此时文件不被视为US-ASCII。是否有更简单的方法告诉Ruby“此应用程序是UTF8编码的。请将所有和任何包含的源文件视为UTF8,除非另有声明”?更新:我写了“Howtoinserttheencoding:UTF-8directiveautomaticallyinRuby1.9files”,它会在需要时自动附加编码指令。 最佳答案 我觉得你可以

ruby-on-rails - 从 Rails 模型内部访问翻译文件 (i18n)

我的模型中有:defbody_color_enum[['Aqua','#009c9c'],['Grey','#6d6e71'],['Yellow','#ffe600'],['White','white']]end我希望这些值来自翻译文件“en.yml”en:group:hero:hex1:'#6d6e71'name1:'Darkgrey'hex2:'#ccc'name2:'Lightgrey'hex3:'#0099ce'name3:'Blue'hex4:'#ffffff'name4:'White'我试过这个:defbody_color_enum[[t('group.hero.name1

ruby-on-rails - Rails Migrations 可以用来转换数据吗?

我正在尝试转换我的Rails应用程序中的列,为了论证,让我们假设我正在尝试将我的users表中的age列更改为字符串表示形式而不是int。在我的迁移中我有这个;def.selfupadd_column:users,:age_text,:stringusers=User.find(:all)users.eachdo|u|u.age_text=convert_to_text(u.age)u.saveendenddefself.convert_to_text(number)#codeheretoconvert1to'one'etcend但它似乎没有用,我在这里尝试的是否可以通过迁移实现?

ruby - 将 2 元素数组的数组转换为散列,其中重复的键附加附加值

例如给定一个数组:array=[[:a,:b],[:a,:c],[:c,:b]]返回以下哈希值:hash={:a=>[:b,:c],:c=>[:b]}hash=Hash[array]覆盖以前的关联,产生:hash={:a=>:c,:c=>:b} 最佳答案 使用功能性婴儿步骤:irb:01.0>array=[[:a,:b],[:a,:c],[:c,:b]]#=>[[:a,:b],[:a,:c],[:c,:b]]irb:02.0>array.group_by(&:first)#=>{:a=>[[:a,:b],[:a,:c]],:c=>[

ruby-on-rails - Ruby:阅读 PDF 文件

我正在寻找一种在Ruby中(在Linux和OSX上)读取/解析大型PDF文件的快速可靠的方法。直到现在我才找到相当古老和简单的PDF-toolkit(一个pdftotext-包装器)和PDF-reader,它无法读取我的大部分文件。尽管这两个库提供了我正在寻找的功能。我的问题:我错过了什么吗?是否有更适合(更快、更可靠)解决我的问题的工具? 最佳答案 您可能会找到Docsplit有用的:Docsplitisacommand-lineutilityandRubylibraryforsplittingapartdocumentsinto

ruby - 为什么哈希中的这个字符串键转换为符号?

使用ruby2.3:在示例1中,字符串键"a"自动转换为符号,而在示例2中,它仍然是一个字符串。示例1{"a":1}#=>{:a=>1}示例2{"a"=>"c"}#=>{"a"=>"c"}我认为:与旧式哈希火箭=>语法相同。到底是怎么回事?为什么我在Rails中从未注意到这一点?是HashWithIndifferentAccess掩盖了这一点吗? 最佳答案 在Ruby2.3(.0)中,这些都是一样的:{:"a"=>1}{"a":1},{:a=>1}{a:1}它们都翻译成同一个东西:a在所有这些情况下都是一个符号。{"a"=>1}不同

ruby - 为什么 "slurping"文件不是一个好习惯?

为什么“slurping”文件不是普通文本文件I/O的好做法,什么时候有用?例如,为什么我不应该使用这些?File.read('/path/to/text.txt').lines.eachdo|line|#dosomethingwithalineend或File.readlines('/path/to/text.txt').eachdo|line|#dosomethingwithalineend 最佳答案 我们一次又一次地看到询问有关读取文本文件以逐行处理它的问题,这些问题使用read或readlines的变体,它们将一次将整个文件